import java.util.Arrays;

/**
 * Created with IntelliJ IDEA.
 * Description:选择排序
 * User: 东莞呵呵
 * Date:2022-06-20
 * Time:10:03
 */
public class SelectSort {
    /**
     * 从待排序的数据中找到最大或者最小的数据放在最前或最后
     * 不稳定排序，不管数据有序无序
     * 时间复杂度都是O（n^2）
     */
    public static void selectSort(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            int minIndex = i;//是从i开始的最小值
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[minIndex] > arr[j]) {
                    minIndex = j;
                }
            }
            int tmp = arr[i];
            arr[i] = arr[minIndex];
            arr[minIndex] = tmp;
        }
    }

    public static void main(String[] args) {
        int[] arr = {65, 43, 5, 7, 4, 5, 76, 23, 4, 765, 42, 6, 7, 8};
        selectSort(arr);
        System.out.println(Arrays.toString(arr));
    }
}
